home *** CD-ROM | disk | FTP | other *** search
/ Amiga Plus 2000 #5 / Amiga Plus CD - 2000 - No. 5.iso / Tools / Dev / lame_src / quantize-pvt.h < prev    next >
Encoding:
C/C++ Source or Header  |  2000-01-01  |  4.1 KB  |  133 lines

  1. #ifndef LOOP_PVT_H
  2. #define LOOP_PVT_H
  3. #include "l3side.h"
  4. #define IXMAX_VAL 8206 /* ix always <= 8191+15.    see count_bits() */
  5. #define PRECALC_SIZE (IXMAX_VAL+2)
  6.  
  7.  
  8. extern int convert_mdct, convert_psy, reduce_sidechannel;
  9. extern unsigned int nr_of_sfb_block[6][3][4];
  10. extern int pretab[SBMAX_l];
  11. extern const int slen1_tab[16];
  12. extern const int slen2_tab[16];
  13.  
  14. extern const scalefac_struct sfBandIndex[9];
  15.  
  16. extern FLOAT8 pow43[PRECALC_SIZE];
  17. extern FLOAT8 adj43[PRECALC_SIZE];
  18. extern FLOAT8 adj43asm[PRECALC_SIZE];
  19.  
  20. #define Q_MAX 330
  21.  
  22. extern FLOAT8 pow20[Q_MAX];
  23. extern FLOAT8 ipow20[Q_MAX];
  24.  
  25. typedef struct calc_noise_result_t {
  26.     int over_count;        /* number of quantization noise > masking */
  27.     int tot_count;        /* all */
  28.     FLOAT8 over_noise;    /* sum of quantization noise > masking */
  29.     FLOAT8 tot_noise;    /* sum of all quantization noise */
  30.     FLOAT8 max_noise;    /* max quantization noise */
  31.     FLOAT8 over_avg_noise;    /* over_noise / over_count */
  32.     FLOAT8 tot_avg_noise;    /* tot_noise / tot_count */
  33. } calc_noise_result;
  34.  
  35. void compute_ath(lame_global_flags *gfp,FLOAT8 ATH_l[SBPSY_l],FLOAT8 ATH_s[SBPSY_l]);
  36. void ms_convert(FLOAT8 xr[2][576],FLOAT8 xr_org[2][576]);
  37. int on_pe(lame_global_flags *gfp,FLOAT8 pe[2][2],III_side_info_t *l3_side,
  38. int targ_bits[2],int mean_bits, int gr);
  39. void reduce_side(int targ_bits[2],FLOAT8 ms_ener_ratio,int mean_bits,int max_bits);
  40.  
  41.  
  42. void outer_loop( lame_global_flags *gfp,
  43.                 FLOAT8 xr[576],     /*vector of the magnitudees of the spectral values */
  44.                 int bits,
  45.         FLOAT8 noise[4],
  46.                 III_psy_xmin *l3_xmin, /* the allowed distortion of the scalefactor */
  47.                 int l3_enc[576],    /* vector of quantized values ix(0..575) */
  48.          III_scalefac_t *scalefac, /* scalefactors */
  49.          gr_info *,
  50.                 FLOAT8 xfsf[4][SBMAX_l],
  51.         int ch);
  52.  
  53.  
  54.  
  55. void iteration_init( lame_global_flags *gfp,III_side_info_t *l3_side, int l3_enc[2][2][576]);
  56.  
  57. void huffman_init(void);
  58.  
  59. int inner_loop( lame_global_flags *gfp,FLOAT8 xrpow[576],
  60.                 int l3_enc[576],
  61.                 int max_bits,
  62.                 gr_info *cod_info);
  63.  
  64. int calc_xmin( lame_global_flags *gfp,FLOAT8 xr[576],
  65.                 III_psy_ratio *ratio,
  66.                 gr_info *cod_info,
  67.                 III_psy_xmin *l3_xmin);
  68.  
  69. int scale_bitcount( III_scalefac_t *scalefac, gr_info *cod_info);
  70. int scale_bitcount_lsf( III_scalefac_t *scalefac, gr_info *cod_info);
  71. int calc_noise( lame_global_flags *gfp, FLOAT8 xr[576],
  72.                  int ix[576],
  73.                  gr_info *cod_info,
  74.                  FLOAT8 xfsf[4][SBMAX_l], 
  75.          FLOAT8 distort[4][SBMAX_l],
  76.                  III_psy_xmin *l3_xmin,
  77.          III_scalefac_t *,
  78.                  calc_noise_result *);
  79.  
  80. int loop_break( III_scalefac_t *scalefac, gr_info *cod_info);
  81.  
  82. void amp_scalefac_bands(lame_global_flags *gfp, FLOAT8 xrpow[576],
  83.             gr_info *cod_info,
  84.             III_scalefac_t *scalefac,
  85.             FLOAT8 distort[4][SBMAX_l]);
  86.  
  87. void quantize_xrpow( FLOAT8 xr[576],
  88.                int  ix[576],
  89.                gr_info *cod_info );
  90. void quantize_xrpow_ISO( FLOAT8 xr[576],
  91.                int  ix[576],
  92.                gr_info *cod_info );
  93.  
  94. int
  95. new_choose_table( int ix[576],
  96.           unsigned int begin,
  97.           unsigned int end, int * s );
  98.  
  99. int bin_search_StepSize2(lame_global_flags *gfp,int desired_rate, int start, int ix[576],
  100.                          FLOAT8 xrspow[576], gr_info * cod_info);
  101. int count_bits(lame_global_flags *gfp,int  *ix, FLOAT8 xr[576], gr_info *cod_info);
  102.  
  103.  
  104. int quant_compare(int type, calc_noise_result *best_noise, calc_noise_result *noise);
  105.  
  106. void best_huffman_divide(lame_internal_flags *gfc, int gr, int ch, gr_info *cod_info, int *ix);
  107.  
  108. void best_scalefac_store(lame_global_flags *gfp,int gr, int ch,
  109.              int l3_enc[2][2][576],
  110.              III_side_info_t *l3_side,
  111.              III_scalefac_t scalefac[2][2]);
  112.  
  113. void inc_scalefac_scale(lame_global_flags *gfp,
  114.             III_scalefac_t *scalefac,
  115.             gr_info *cod_info,
  116.             FLOAT8 xrpow[576]);
  117.  
  118. void inc_subblock_gain(lame_global_flags *gfp,
  119.                III_scalefac_t *scalefac,
  120.                gr_info *cod_info,
  121.                FLOAT8 xrpow[576]);
  122.  
  123.  
  124. int init_outer_loop(
  125.     lame_global_flags *gfp,
  126.     FLOAT8 xr[576],        /*  could be L/R OR MID/SIDE */
  127.     gr_info *cod_info);
  128.  
  129. #define LARGE_BITS 100000
  130.  
  131. #endif
  132.  
  133.